package triangle;

import java.util.ArrayList;
import java.util.List;

public class Test2 {


    public List<List<Integer>> generate(int numRows) {
        List<List<Integer>> ret = new ArrayList<>();

        List<Integer> list = new ArrayList<>();
        //第一行第一列
        list.add(1);
        ret.add(list);


        for (int i = 1; i < numRows; i++) {
            //当前行
            List<Integer> curRow = new ArrayList<>();
            //首位均为 1
            curRow.add(1);
            //中间的
            for (int j = 1; j < i; j++) {
                //i = 1是当前行，那 i - 1就是上一行
                List<Integer> preRow = ret.get(i - 1);
                int x1 = preRow.get(j);
                int x2 = preRow.get(j - 1);
                curRow.add(x1 + x2);
            }
            //当前行，最后一个 1
            curRow.add(1);
            ret.add(curRow);

        }
        return ret;
    }

    public static void main(String[] args) {
        Test2 test2 = new Test2();
        System.out.println(test2.generate(5));
    }
}
